<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <input type="text" id="ele">
    <script>
        const ele = document.getElementById('ele');
        Object.defineProperty(ele,'type',{
            get() {
                // 为什么不能用 this.type? 防止get方法死循环
                return this.getAttribute('type') || 'text';
            }
        })
        // ele.type = 'number';
        // console.log(ele.type);
        // console.log(ele.type = 'number'); // 返回值为被设置的值；
        // console.log(Reflect.set(ele,'type','number')); // Reflect 上的 set 方法返回一个boolean值,表示是否设置成功；
        
    </script>
</body>
</html>